草庐IT

c++ - PIMPL 和堆栈分配

全部标签

c - Data_wrap_struct 和标记函数

我正在编写一个Ruby扩展,我正在使用函数Data_wrap_struct。为了参与Ruby的标记和清除垃圾收集过程,我需要定义一个例程来释放我的结构,以及一个例程来标记从我的结构到其他结构的任何引用。我通过经典的free函数来释放内存,但我不知道如何使用标记函数。我的结构听起来像这样typedefstruct{intx;inty;}A;typedefstruct{Acollection[10];intcurrent;}B;我认为我需要一个标记函数来标记结构B的collection中的引用。谁能给我看一个例子,看看标记函数是如何工作的? 最佳答案

c - C 扩展中的 Ruby 关键字参数

如何处理来自C扩展的Ruby2.0.0关键字参数?背景defexample(name:'Bob'hat_color:'red')puts"#{name}hasa#{hat_color}hat!"endexample#=>"Bobhasaredhat!"example(name:'Joe',hat_color:'blue')#=>"Joehasabluehat!"关键字参数(如上)在处理具有许多不同调用序列或选项的方法时非常有用。我在C扩展中有一个这样的方法(一种处理我项目中大部分OpenGL绘图的blit方法),我想知道如何让该方法处理来自ruby​​的关键字参数。想法根据我所做的一些

c - Ruby 的 Enumerable#zip 是否在内部创建数组?

在Ruby-ComparetwoEnumeratorselegantly,据说Theproblemwithzipisthatitcreatesarraysinternally,nomatterwhatEnumerableyoupass.There'sanotherproblemwithlengthofinputparams我查看了YARV中Enumerable#zip的实现,并看到了staticVALUEenum_zip(intargc,VALUE*argv,VALUEobj){inti;IDconv;NODE*memo;VALUEresult=Qnil;VALUEargs=rb_ar

我可以覆盖用 C 编写的 Ruby 方法吗?

是否可以使用Ruby代码覆盖Ruby本身的一部分方法,例如rb_error_frozen,它们是用C语言编写的?背景:我想知道当卡住的对象被修改时,是否有可能让Ruby仅记录警告,而不引发异常。这样,我可以记录各种状态修改,而不是在第一次发生时停止。我主要考虑使用YARV执行此操作,但如果这样更容易,我可以使用其他实现。是的,这是一个whyday项目!不要在生产环境中尝试这个! 最佳答案 我只能代表MRI/YARV,但我会试一试。如果C函数已明确定义为Ruby对象上的方法,则只能在Ruby中覆盖源自C的函数。例如,Kernel#ex

ruby - 在 heroku cedar 堆栈上部署 sinatra 应用程序(使用 config.ru)

我正在尝试重构我的sinatra代码以将我的主文件分成单独的文件,使用来自thisresponse的一些技巧,我在部署到heroku时遇到了麻烦。以前我没有config.ru文件,只是使用了我的Procfile,它是:web:bundleexecrubyweb.rb-p$PORT根据thisarticle.从重构开始,我现在将Procfile更改为web:bundleexecthin-Rconfig.rustart-p$PORT我的config.ru文件是root=::File.dirname(__FILE__)require::File.join(root,'web')runMyAp

ruby-on-rails - activesupport 回调中的堆栈级别太深

我在Rails3应用程序中收到SystemStackError。我拥有的所有信息都是无用的一行堆栈跟踪(从日志中获取):SystemStackError(stackleveltoodeep):activesupport(3.2.3)lib/active_support/callbacks.rb:409所以问题是我如何查看完整的堆栈跟踪?注意:我不关心为什么会发生这种情况,我只想知道它发生在何处。使用:Rails3.2.3,Unicorn。谢谢。 最佳答案 如果您在before_save或after_save中更新事件记录,它将继续循

ruby-on-rails - 无法分配请求的地址 - bind(2) (Errno::EADDRNOTAVAIL)

我在centos6.3服务器上使用railforteambox,实际上这只是在实际应用之前的试错。我正在使用2个运行在相同centos版本和精确副本上的虚拟机,VM2只运行远离VM1的mysql我试过mysql连接#nc并且它已连接VM1(192.168.7.201)&VM2(192.168.7.202运行MYSQL)我在my.cnf中的远程机器(VM2)上有bind-address,bind-address=192.168.7.202这是我的database.ymldevelopment:adapter:mysqlhost:192.168.7.202port:3306username

ruby-on-rails - 如何在 Rails ActiveRecord 中正确分配 has_many/belongs_to 关系?

我有一个带有文章和作者模型的Rails应用程序。如果我有一个作者和一个帖子,并且想表明作者应该是文章的所有者,或者文章属于作者,那么这样做的最佳做法是什么?特别是:如果我设置了会有什么不同my_article.author_id=author_one.id或者如果我这样做author_one使用的关联是作者有_多篇文章文章属于作者另外,如果出现类似问题,最好的查找方式是什么? 最佳答案 以下3个没有区别:my_article.author_id=author_one.idmy_article.save#sameasmy_articl

ruby - 为什么 Ruby 倾向于按降序分配对象 ID?

我注意到对象的ID分配方式有悖常理。一个对象创建得越早,它的对象ID就越大。我原以为它们会按升序分配,而不是相反。例如:obj1=Object.newobj2=Object.newobj3=Object.newpobj1.object_id#=>4806560pobj2.object_id#=>4806540pobj3.object_id#=>4806520为什么它们以这样的方式分配,为什么在Ruby解释器运行的代码中步长为20,而不是1,但在Ruby的irb运行的代码中,对象ID之间的差异要大得多? 最佳答案 经过许多细节,rub

Ruby 堆栈级别太深异常不是来自递归无限循环

编辑:(已解决)实际上它可能是因为无限循环而引发的我正在编码,在添加一个方法后我得到了这个:user_name@the_computer:/media/ECC3-C3B0/Prog/mts/src/mts$raketest--trace**Invoketest(first_time)**Executetest/home/user_name/.rvm/rubies/ruby-1.9.3-p194/lib/ruby/site_ruby/1.9.1/rubygems/custom_require.rb:36:stackleveltoodeep(SystemStackError)rakeabo